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(54) Gaming device identification method and apparatus 

(57) An electronic memory which cannot be modi- 
fied or erased, such as one-time programmat^e or add- 
only (OTP/AO) memory is used for storing direct or indi- 
rect indications of characteristics of a gaming terminal 
or its conrponents. Preferably, a plurality of gaming ter- 
minal tx^ards irKludes memory that has one or more 
rows of OTP/AO memory for storing information such as 
memory or kx>ard serial numbers, manufacture date, 
processor speed or type, software or hardware version 
numbers, and the like. Such information is preferably 
used in connection with assuring the appropriateness of 
modifications or configurations of the gaming terminal, 
such as downloading software or other software modifi- 
cation arKl/or changes to hardware configuration. 
OTP/AO information can be used in connection with 
verifying identity or characteristics of software or hard- 
ware, e.g. for wananty purposes. The non-erasable and 
non-modifiable nature of the information provides 
assurance that software downloads or other modifica- 
tions will not be inappropriate because of inadvertent or 
intentional misidentif ication of a component. 
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Description 

FIELD OF THE INVENTION 

[0001] The present invention relates an identif cation method and apparatus for use in identifying componmts of a 
gaming da/ice such as a slot machine^ card game machine, keno machine and the like, and. in particular, identification 
for machine conponents using a non-erasat)le electronic memory or memory portion such as a memory with write- 
once or add-only characteristics. 

BACKGROUND INFORMATION 

[0002] Many current gaming machines are configured with electronic components, commonly moirited on one or 
more printed circuit boaids (RGBs). Many such electronic components use programming or other information stored In 
memories. In at least one typical configuration, a ganring terminal or gaming machine will include a controller board, a 
communications board or module, and one or more so-called peripheral boards.such as a display controller board, a 
currency acceptor board, a coin handler board, and the like. Typicatty one or more of the boards, such as, e.g., the game 
controller board, a processor (microprocessor) or other computer unit which often operates based on programming or 
other infbmiation (software or f innware) stored in a mennory such as one or more electronically erasable programmable 
read-only memories (EEPROMS). Such software or firmware may be programmed or stored in the memory locations 
during the manufacturing or assembly of the gaming device. Additionally, software or firmware may be provided to 
replace or supplement the software or firmware in a gaming device which is in operation (in the f ieW), e.g. to update the 
machine configuration (such as adding new features, new games and the like, and/or to correct programming errors), 
in either case, the new firmware or software is transferred or "downloaded" from a source (which may be. e.g.. a com- 
puter such as a workstation, personal computer, laptop computer, and the like) to the "target" memory in a particular 
gaming terminal or machine. 

[0003] Although downloading from one computer to another is, in general, a process that is currently known, down- 
loading software or firmware to components of gaming devices presents particular problems not readily addressed by 
conventional downloading techniques and apparatus. 

[0004] One feature applicable to gaming device downloading is the stringent regulatory oversight and control exer- 
cised by gaming regulatory authorities in many jurisdictions. In many, and perhaps all. regulated gaming jurisdictions, 
downloading of software or firmware to a gaining terminal will not be permitted without some assurance that the new 
software or firmware will comply with local regulations. For example, a gaming regulatory authority in one jurisdiction 
may require assurance that downloading to. e.g.. update bill acceptor software will result in a machine having bill Rap- 
tor software appropriate (and approved) for ^t jurisdiction (and will not. e.g., run the risk of inadvertently and/or inten- 
tionally downloading bill acceptor software that was approved in a different jurisdiction, or not at all). 
[0005] It is also commonly found that gaming devices occur in a wide variety of configurations, such as employing 
numerous different types of processors, memories, game configurations, versions and types, peripheral hardware and 
softvk/are and the like. Additionally, owing to differences in manufacturing dates, maintenance history and the like, gam- 
ing devices are often encountered with a wide variety of different hardware and software components which may not be 
apF>arent (or may be dtscernat)le only with difficulty) from a visual inspection of the gaming device, its components or 
operation. For this reason, when it is desired to download software to a particular gaming ternrinai. It is typically neces- 
sary to select a particular software version for downloading, bearing in mind the types of software and hardvtfare found 
on the particular gaming terminal, lest the newly-downloaded software is incompatible with the gaming terminal or 
results in operation which is not approved by a particular jurisdiction. Additionally, it is possible that the software or 
firmware vihich is to be downloaded is, in fact, already present on a particular gaming terminal so that the download 
process represents a waste of time and effort 

[0006] In typical previous situations, in order to download software or firmware to a gaming terminal, characteristics 
of the gaming terminal and/or its oonrponents were determined manually, such as by visually inspecting the compo- 
nents and/or running tests of diagnostics on a component in an attempt to determine characteristics such as the version 
or type of a particular board, the processor speed associated with a particular board, the version of software or hard- 
ware conponents. and the like. Such manual determination of characteristics has, in the past, typically required a sig- 
nificant investment of time, especially when a relatively large number of gaming terminals are being programmed or re- 
programmed, and. to make matters vworse. the time investment is typically made by relatively highly-trained personnel 
who have the t>ackground and experience required to analyze the hardware/software components that are present. 
Such investment of time by relatively highly-trained personnel represents a signif icant expense involved in downloading 
information which, owing at least partly to the regulatory environment found for gaming devices, was previously believed 
to be largely unavoidable. Furthermore, it has been found tiiat even relatively highly-trained personnel have a undesir- 
ably high error rate when attempting to determine charactoristicft heeded for a download, which may load to inoperabil- 
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tty or improper operation of a gaming device, violation of gaming jurisdiction laws or rules and may require an additional 
investment of time to detect and/or conrect such en-ors. 

[Q007] In addition to a downloading context identification of gaming device components or component characteris- 
tics may be useful in the context of gaming device maintenance, service or wananty futfillment For example, when 

5 determining whether a repair of a gaming terminal is covered by a wanranty. it may be necessary to determine when the 
gaming terminal was manufactured or when one of the components was manufactured or last repaired or revised. 
[0008] Another feature of many gaming devices which affects the manner in which revisions of software or firmware 
(or hardware) can or should be performed is the fact that gaming devices are often configured to dispense mon^ so 
that there is a potential for nvxiif ications or downloads to be intentionally performed in an unauthorized fashion in such 

10 a manner as to create unauthorized or improper F>ayouts. This is a potential which is typically not present in many other 
types of downloads from one computer to another. Accordingly, it is important, not only to gaming regulatory authorities 
but also casinos or other game operators, to achieve a level of confidence that, not only will inadvertent (e.g. cross-juris- 
dictional) downloads be avoided, but there are procedures in place to avoid or prevent intentional or unauthorized down- 
loads. 

15 [0009] Aocordingiy. it would be advantageous to provide a method and apparatus for downloading by which the 
characteristics of a gaming terminal needed to avoid inadvertent or intentional improper downloads can t>e determined 
substantially automatically, i.e. while reducing, or. preferably, elinninating the need for manual characteristic determina- 
tion, visual inspection of machines, their components or operation and the like. It would be particularly advantageous 
to provide a download process which can obtain such gaming terminal or gcuning terminal component characteristics 

20 entirely automatically, i.e. using only computers or otiier machines and without the need for any human input or effort 
to accomplish such determination of cfiaracteristics. It would further be advantageous to provide such a system and 
method which would reduce or eliminate the potential for errors in. or unauthorized tampering with, tiie identification 
system. 

25 SUM^4ARY OF THE INVENTION 

[0010] The present invention includes providing gaming terminal or gaming terminal conrponents with information 
usable for characterizing gaming terminal components, which is electronically stored in a nnemory or portion of memory 
which is add-only memory (AO) or one-time programmable (OTP) memory. By storing, in such memory, information 

30 which either uniquely identifies a conponent or identifies characteristics of a component, it is possible to configure a 
download system which can automatically ot>tain the information needed to perform a download while achieving a level 
of security required to nriake such automatic download feasible in view of ttie requirements of gaming regulators and/or 
game operators. In one embodiment, a game controller card arxl a plurality of peripheral cards are each provided with 
certain memory locations which contain information in a fashion that such information, as a practical matter, cannot be 

35 erased or changed. Such memory locations can be used to store, e.g.. a unique serial numt>er or other unique identifier, 
hardware characteristic information such as processor type or speed, vendor identification, date of manufacture, arxi 
the like. In this way. before downloading information to a gaming terminal, it is possible to automatically (substantially 
without human intervention or effort) verify that the download will be proper, such as to verify that the jurisdiction for 
which the gaming terminal is configured (or where the casino or other purchaser is located) is the same as the jurisdic- 

40 tion for which tiie new software has been approved, to verify that the dock speed and/or data transfer speed for which 
the new software is designed (or at which the download is to take place) is compatible with the clock speed of the gam- 
ing terminal or Its conponent. that the software to be downloaded is known to be compatible with other software and/or 
hardware on the gaming terminal that will remain in place. arKl the like. 

45 BRIEF DESCRIPTION OF THE DRAWINGS 

[0011] 

Figs. 1 A and B are block diagrams depicting components of multi-terminal gaming or production systems, including 
50 components of a gaming terminal of a type which may t>e used in connection with the present invention: 

Figs. 2A and B are block diagrams illustrating examples of memories which may be used in connection with an 
embodiment of the present irwention. 

DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENT 

55 

[0012] Although the present invention can be used in connection with many types of gaming terminals, either as 
starxj-alone devices or coupled in any of a number of different multi-terminal configurations. Fig. 1 A depicts one exam- 
ple of a gaming terminal 1 12a coupled, along with other gaming terminals 1 12. via one or more local controllers 114 
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a,b.c to a central conr^uter 116. In the embodiment of Fig. 1 A, gaming temiinal 112a (and, typically, all gaming tenni- 
nals in the group) includes a game controller board 122 which will typically include, among other items, a microproces- 
sor and a memory such as an EEPTOM storing programming and/or other information for controlling operation of the 
controller board 122. Typically the hardware and software of the game controller board 122 will contain information or 
programming d^ining the type of game and making determinations of local win/loss outcome (as opposed to, e.g., non- 
local, progressive win/loss outcomes) for the gaming terminal 1 12a. Because of the central role of the game controQer 
board 122 in determining game win/loss and, thus, in determining any monetary payout it is particularly important to 
assure the presence of the correct softwvare for the game controller board e.g. to avoid improper or incorrect payouts 
and to assure compliance with local regulatory authorities. 

[001 3] AHhough it ts possible to combine numerous functions onto a given board, typically numerous t>oard8 will be 
provided in a gaming terminal for forming a plurality of functions. In the depicted embodiment, the game controller board 
cormuinicates with a conruruinications tx>ard 124 which provides information to and. receives information from a local 
controller ll4a and/or central computer 116, tor purposes such as monitoring use and perfornrwmce, assuring compli- 
ance, performing accounting arxJ similar functions, arxl facilitating implementation of progressive or other multi-terminai 
based games or prize& In one embodiment the communications board 124 includes one or nx>re ports by which a lap- 
top 128 or other computer may be coupled to the gaming terminal 1 12a for. among other purposes, downloading as 
described more fully below. 

[0014] In the embodiment of Rg. 1 A, a plurality of peripheral boards I28a-d communicate with the game controtter 
t>oafd 122 and control various peripheral devices for performing various functions such as bill acceptor functions 132a. 
coin harxiling functior^ 134a, 132b. video functions 132c and audio output functions 132d. In many configurations, 
some or all of the peripheral emd other boards 1 28a-d. 1 24 will contain memories, such as flash memory, EEPROMs or 
other devices for storing software or firmware controlling their functions (such as by containing software or firmware for 
running on nr^croprocessors or other computing devices on such boards). In the strict regulatory environment for many 
gaming devices, it is typically necessary to provide assurance that only approved and proper software is used in the 
peripheral and other boards, (in addition to that provided on the game controller board). 

[0015] In typical previous devices, the boards provided in a gaming terminal are secured from casual or unauthor- 
ized inspection or access such as by being housed in a normally-locked cabinet portion of the gaming terminal. Thus, 
in previous systems when it was desired (as descrtoed above) to (manually) verify the type or characteristics of boards 
on a gaming terminal (e.g. prior to a download or other updating purpose or for warranty or sen/ice purposes) it was 
typically necessary for a relatively highly trained worker to inactivate a gaming terminal, unlock the catsinet portion, and 
physically inspect (often involving removal of) one or more of the txjards 122-128 of a gaming terminal 1 12a. Depending 
on the nature of the work to be performed, the skilled personnel may need to rely on experience and knowledge to rec- 
ognize and distinguish different t)oards t>ased on their appearance and/or notations, markings or indicia provided on 
boards and/or perform tests or diagnostics on the board to obtain the necessary information regarding characteristics 
of the tx>ard and/or its identity or history. 

[0016] Fig IB depicts a system usable in subassembly or final assemt)ly downloading, e.g., in a gaming terminal 
manufacturing environment Rg. 1 B includes a plurality of computers such as workstation computers, netwvork server 
conputers. and/or PC-type corrputers coupled by network lines such as fiber optic Unes 152 in a manner well-known 
to those of skill in computer network technologies. 

[0017] At various stages in employing the system of Rg. 1 B, programming data or other information is stored in a 
nunrt)er of different storage systems such as data bases (typically providing storage on hard drives or other well-known 
storage media). In the depicted embodiment, information, during program design process, is held in an engineering 
database 154. And software and firmware engineers use and modify such information via computers 156, 158 having 
at least indirect access to engineering database 154. Preferably, programs or other data which are still in the develop- 
ment phase are restricted to the engineering database 154 and are not stored in other databases. At some point engi- 
neering will release the program or other information to product assurance 162 which, after review, will submit the 
progranvning or data (e.g. via writing on a CD 164 to a gaming jurisdiction for approval. After the program or data is 
approved by the gaming jurisdiction, the program is copied to a production download server 1 66 and, preferably, stored 
in a released database 168. Information about the approved program is provided to a customer order system 172 and 
other systems such as engineering 1 74a and product assurance 1 74b. Although released programs may be provided 
in various forms such as on CD ROM 1 76 via a CD duplicator 1 76b. Rg. 1 B also illustrates a system for downloading 
programming data or other information as part of a gaming terminal assembly or fabrication system. The programming 
or data may be loaded onto boards or other sut>assemblies 1 78. e.g. via a translator/power assemtJy 1 82 and download 
terminal 184 or may be loaded into one or more gaming terminals 186a.b. e.g. via connection to a comnruinication board 
for downloading, in turn, to target peripheral devices or other subasserrtlies within the gaming terminals 186a. 186b. 
e.g. via a download terminal 188. 

[0018] As with downloading in the field, as depicted in Rg. 1 A, downloading on the fabrication or assembly line, as 
depicted in Rg. IB in the strict regulatory environment for many gaming devices, it is typically necessary to provide 
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assurance that only approved and proper software and data is used in the gaming terminals, induding peripheral and 
other boaids (in addition to that provided on. e.g. , the game controller board). Depending on the nature of the download, 
it will be advantageous, in performirtg assenrtbly line downloading, to recognize or distinguish different boards, ag. to 
obtain information regarding characteristics of the Board and/or its identity or history. 

5 [0019] According to an embociment of the invention, automation of the step of obtaining gaming terminal corrpo- 
nent characteristics is enabled or facifitated by including, on one or more of the gaming terminal boards or other com- 
ponents, an electronic memory device, e.g., of the type depicted in block diagram fashion, in Rgs. 2A or 2B. 
[0020] In the embodiment of Rg. 2A, a menx>ry device such as an EEPROM 212 is provided with a plurality of 
memory locations 214 which are preferat)ly of a type which may be programmed or written-to many times. The memory 

10 device 212 i$ also provided with at least some memory locations 216 (such as a one or more rows of memory) which 
are configured such that they carvx>t be erased or changed after they have been written to or programmed. In the 
embodiment of Fig. 2A. the memory locations 216 are write-once or one time programmable (OTP) memory, meaning 
that after ar^ of the program locations in the memory region 216 have been written to or programmed, suteequerrtly 
none of the memory locations in the memory region 21 6 can tse changed or erased. One example of this type of mem- 

15 ory is that sold urxler Model No. M34R32 avaitat)le from S.Q.S. Thomson. This device provides 4096 bytes of EEPROM 
space 214 with an additional 32-byte OTP row 216. 

[0021] Rg. 2B depicts a type of memory having a plurality of programrr^e memory locations 214 and a region of 
memory 218 (such as a row of memory) which is add-only (AO) memory. In add-only memory, it is possible to write to 
or program some of a plurality of menx>ry locations 222a-222f. without writing to others. In the 6Kid-only row 218. after 

20 any merrxKy location or group of locations 222 have l:>een written to or programmed, those same memory locations can- 
not thereafter, be changed or erased. However. m6nrx>ry locations in ttie row 218 which have not been previously writ- 
ten to or programmed can be, later, written to or programmed (once) even after a process of writing to or programming 
other memory locations in the same region or row 218. For example, in add-only menrx>ry, it is possible to program, ag., 
a first memory location 222a at a first time such that the first memory location 222a cannot thereafter be changed or 

25 erased after said first time, but to still permit programnrting or writing to. ag. a second (previously unprograrrvned) mem- 
ory location 222b at a second time, after said first time, such that the second memory location 222b cannot t>e changed 
or erased after the second time. In tiiis way. as long as there remain memory locations in the add-only region 218 which 
have not previously been programmed or written to. it is possible to add furtiier infbrnnation to the add-only region 218. 
However, although it is possible to add information to the region 218 (as long as unprogrammed space remains) it is 

30 never possible to erase or change information once it has been written to the add-only region 21 8. One example of add- 
only menrx)ry is availat)le from Dallas Semiconductor. 

[0022] According to an embodiment of the invention. OTP or add-only (OTP/AO) memory is provided in each gam- 
ing terminal, preferatsly on at least one board of each gaming terminal (such as the game controller board) and, typi- 
cally, on one or more peripheral boards 128a-128d or other boards or components. It is possible to provide for systems 
35 in which some gaming terminals 1 1 2a are provided with OTP/AO memory while others e.g. 1 12c are not (ag. whea in 
the context of a networked casino system, some gaming terminals have been upgraded or replaced while others have 
not). 

[0023] There are three major procedures or steps in connection with using such OTP/AO merTX)ry in embodiments 
of the present invention: storing the desired information onto the OTP/AO memory, reading or retrieving the information 

40 Stored in the OTP/AO region, and using such retrieved information, e.g. for secure downloading. These processes 
involve communicating information between the OTP/AO memory and an external (to the gaming ternrtinal) device (typ- 
ically one or more computers 116,1 28). Although it would be possible to configure a system in which a gaming terminal 
contains only a single OTP/AO memory device which stores information relative to a plurality of different hardware com- 
ponents (such as identifying two or more different boards 122a-128d) it is preferred to provide a separate OTP/AO 

45 device on each separate board. In this way. changes to hardware (or, in some configurations, software) can be recorded 
directiy on the changed componerrt so that when components are physically removed (such as '^swapping in** a new 
board) and/or modified (suc^ as by changing jumper connections on a board) information relating to the identity and/or 
configuration of that tx>ard. stored on the on-board OTP/AO mennory. will travel with** the board. 
[0024] Although it would be po8stt>le to configure a gaming terminal so that two or more boards (such as each 

so board having an OTP/AO memory) were provided with a port or other connection specific to that board, to facilitate 
reading the OTP/AO menwry of that board, preferably, the gaming terminal is provided with one or nrxjre system ports 
126 or similar communication connections 127 through which it is possible to obtain or fransmit information relating to 
any of a plurality of OTP/AO memories in the gaming terminal (e.g. via gaming terminal txjses or other internal conwnu- 
nication links 130 a-f). The ports 126.127 may be provided on any of a number of gaming terminal conrponents includ- 

55 ing the game controller board 1 22, but are preferably included in a separate communications board 1 24. 

[0025] The information stored on the OTP/AO memory may indicate characteristics of the board's (or other conrpo- 
nents) hardware or software either directly or indirectiy. The information may indicate characteristics directly by. ag.. 
storing information in either coded or human readable (e.g. ASCII character form) which identifies such characteristics 
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such as storing board or download dock speed, board processor type and the like. An exanple of information which 
indirectly indicates hardware or software characteristics of the board or component includes storage of an EEPROM 
serial nurrber (which. e.g.. may be used as an index into an off-board database which stores characteristics corre- 
sponding to such serial number). It is possible to store both direct and indirect indicators of characteristics on an 
5 OTP/AO memory. It is also possible to store information which has both indirect arxj direct uses. For example, storvig 
a date of manufacture on an OTP/AO memory may be used as all or part of an index into a database to determine other 
board characteristics and/or may be used directly, where the date of manufacture is itself a relevant characteristic (such 
as for warranty or repair purposes). 

[0026] Inlbrmation may be stored into OTP/AO memory in a number of fashions. In one enrtxxliment some or all 
10 of the information stored in the OTP/AO menrwry is stored at the time of menrxxy manufacture, by the memory fabrica- 
tor. Exarrples of information that may be stored in this fashion include memory serial (or other preferably unique) num- 
k>ers and/or date of manufacture. Some or all information stored in an OTP/AO memory may be stored at the time of 
board manufacture (rather than memory manufacture) and/or may be stored at the time software Is initially downloaded 
or programmed into a gaming terminal (or components thereof). Exarrples of infomiation that might be stored In this 
15 fashion include board (rather than memory) serial number or version numbers, ck>ck speed, processor type, software 
indicators or version numbers, date of assent)ly (board assembly or gaming terminal assembly) arxl/or an incficator of 
(initial) gaming regulatory jurisdiction (e.g. to distinguish a tx)ard intended for a first country or state from that intended 
for use in a second country or state). 

[0027] Some or all of the information stored on OTP/AO memory may be stored at the time a gaming terminal is 

20 sokj to. shipped to or received at a particular customer location or gaming jurisdiction. Some or all irrformation stored in 
the AO mennory may fc>e stored when a gaming terminal component is revised, repaired, updated, reconfigured or the 
like (including t^oth software arvl hardware revisions). Preferably, the information stored in OTP/AO memory includes 
information that can be used for error or data integrity checks such as cyclic redundancy check (CRC) information, one 
or more parity bits or the like. In the case of write-only or one-time programmable memory the error/data integrity check 

25 information is written when the memory is initially programmed. In the case of add-on menwry, error checking or data 
integrity information may be stored (in a previously unprogrammed AO memory location) each time additional informa- 
tion is stored in the add*on memory The provision of error checking or data integrity information is particularly useful or 
necessary in providing the capability of downloading to gaming terminals (e.g. in order to provide the desirable or 
required confidence that inadvertent or intentional changes are not made to a gaming terminal in such a fashion as to 

30 result in gaming terminal operation which is out of compliance with local gaming regulations). For example, in the 
atasence of cui error or data integrity check, it might be possible that a menrx>ry read error would permit downloading of 
a program configured for a first jurisdiction, into a machine located in a second jurisdiction (e.g. because, the laptop 128 
or other source of download programming selected the \vrong" program or downloading based on incorrect Informa- 
tion). It is believed that providing error or data integrity check information in OTP/AO memory will assist in preventing. 

35 or at least reducing the likelihood of, this type of improper download. 

[0028] Table I provides one example of a set of information that may be stored in OTP/AO memory according to one 
en^xxliment of the inventioa In one enrtxxiiment data stored in the OTP row and/or in the ROM are stored in little 
endian format In the example of Table 1, items irxlicated having a potential use of "revision control" are. in at least one 
embodiment, used during download operations. Preferably the EEPROM serial number is a number which is unique for 

40 each EEPROM (at least for a given vendor and purchaser). The communications ID. may be, e.g. used by the board 
firmware for providing communication to a host computer. The platform and target information may be used in connec- 
tion with. e.g.. host to terminal download commjnications. The verxior ID may be a code used for identifying the verxlor 
of the EEPROM. The clock speed may be used in connection with allowing the peripheral toard firmware to conununi- 
cate with a host conputer. Preferat)ly the CRC is used by the ttoard firmware to validate the OTP data before its use. 

45 [0029] In addition to the data defined in the OTP row. according to one emlxxiiment. the first 20 bytes as of the 
EEPROM normal memory space will be used for storing, e.g.. printed circuit kx>ard serial number information of tiie 
peripheral board, e.g.. stored in ASCII format Preferably, two bytes of CRC information is also provided. To protect this 
information from corruption, preferably the first sixty-four bytes of the EEPROM space is configured as read only mem- 
ory (ROM). 

so 



Table 1 



OTP Row Memory Allocation 


Starting Address 
(hexa- decimal) 


Bytes 


Format 


Description 


Potential Uses 


0x00 


4 


Binary 


EEPROM serial number 


Revision Ckxitrol 
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Table I (continued) 



OTP Row Memory Allocation 


Starting Address 
(hexa- decimal) 


Bytes 


Format 




Potential Uses 


0x04 


1 


Binary 


V,^iiuiiUniCauU>i9 lu 


Used at Powerup for lntra*Ganie Com- 
munications 


0x05 


7 




UaXe Oi rriclrlillawuji c 


W^rranty/Service/Revision Control 


OxOC 


2 


Binary 


rianorm ano wrgei 


Intaivl^ Use 


OxOE 


8 


ASCII 


Vendor ID 


Warranty/OC/Senm:e 


0x16 


1 


Binary 


Clock Speed 


Used at Powerup for Intra-Game Com- 
munication 


0x17 


1 


Binary 


Processor Type 


Used at Powerup for Intra-Game Com- 
munication 


0x18 


6 




Resen/ed for future use 




0x1 E 


2 


Binary 


2-byte CCITT CRC 


En-or/Data Integrity Check 
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15 



20 



25 



30 



35 



40 
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[0030] Although it is contemplated that the gaming terminal component characteristic information stored or indi- 
cated in the OTP/AO memory will be particularly useful in connection with download of information, (as described more 
fully below). It is also believed that the information may be useful in other contexts Examples of other uses for OTP/AO 
information according to embodiments of the present invention, include providing the ability of gaming regulators to ver- 
ify (e.g. on a random basis or for specific regulatory purposes) that a gaming terminal is configured properly for a par- 
ticular jurisdiction, allowing personnel responsible for maintaining, repairing or updating gaming terminals to verify that 
a particular gaming terminal includes particular components, uploading information regarding gaming terminal compo- 
nents e.g. as part of a trouble report, inventory or tracking procedure, verifying characteristics, such as manufacture or 
sale date, of a ganing terminal or con^nents thereof in connection with making decisions on wanranty coverage, and 
the like. 

[0031] Regardless of the purpose for reading information stored on an OTP/AO menwry in a gaming terminal, the 
reading procedure will, at least in one entxxliment. include sending a read command ag. from a laptop 128 or central 
conputer 1 1 6 via a port 126,1 27 to a communications board 1 24. (with the command typically either specifying that all 
OTP/AO memories should be read or specifying which board or OTP/AO board memory should be queried) and send- 
ing a read command (e.g. over a control line or a portion of communication bus 130) which contains or indicates read 
addresses for one or more OTP/AO memory portions. The commands may be configured to retrieve selected 
(addressed) portions or fields of the OTP/AO memory or may be configured to return the entire OTP/AD contents (e.g. 
a OTP/AO -row" of memory). In one embodiment, it is preferred to always return the entire contents of OTP/AO memory 
(particularly in the case of add-on memory) e.g. to help ensure that there has been no imentional or inadvertent storage 
of inconect or misleading information In OTP/AO memory. Fbr example, if a new (previously unprogrammed) field of an 
add-on memory has been programmed to reflect a new jurisdiction (i.e. a jurisdiction different from the onginal gaming 
regulatory jurisdiction programmed in the AO memory) reading the entire row would alert the download software that 
there has been a change in jurisdiction (and. if desired, prompt a check of the database to verify that this change in 
jurisdiction was conect and/or authorized), whereas reading only the newest or most recent f iekds of AO menwy couW 
result in downloading an unauthorized program (e.g. a program authorized only for a different jurisdiction). Thus, in a 
procedure where only the most recently programmed fields are read, there might be no indicator that the jurisdiction 
information may have been tampered with or inadvertently modified. 

[0032] Hardware or software characterizing information read from the OTP/AO memory can be used in a number 
of fashions. In one embodiment, the infomiation is used in downloading software to a gaming terminal (or components 
thereof). Procedures for downloading can be similar to those described e.g.. in U.S. patent application number 

. attorney file no. 3735-923 titled "Method for downloading data to gaming devices* fDed on the 

even date herewith, and/or Serial No. (attorney file number 3735-905-CON). filed June 1 . 1998 

which is a continuation of Serial No. 08/600.31 1 (attorney f He number 27224-90500) for "Peripheral Device Download 
Method and Apparatus" filed February 12. 1996. all incorporated herein by reference. 

[0033] The present invention can be used in connection with a process that involves loading information, received 
from an external device (such as a central computer) by a computing device (such as the microprocessor on the con- 
troller board) to a target which may be a gaming terminal component, including one or more peripheral devices. In this 
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way it is unnecessary to have separate ports on each board for direct access to the peripheral devices (or other gaming 
ternntnal connponents) or related memories, thus making the process of updating the programming for peripheral 
devices or other gaming terminal components less time-intensive and less labor-intensive. In one emtxxliment, an 
updated or modified program is received in the gaming terminal from an external device (such as a hand-held or port- 

5 able device or a central computer coupled via a communications link) and is downloaded or passed-through from the 
controller tx>ard to one or more coupled peripheral devices. Preferably, the programming information is downloaded in 
such a way as to reduce or minimize the amount of down time or inconvenience to players. In one embodiment when 
the new program is downloaded from a central computer to each gaming terminal, the method avoids disabling all gam- 
ing terminals at the same time, such as by waiting until the gaming terminal is idle for a predetermined period before 

TO downloading or by cycling through various gaming terminals or groups of gaming terrrtinals so that a relatively small 
number of the gaming terminals are disabled (for reprogramming) at any one time. When reprogrammtng of two or more 
peripherals attached to a given gaming terminal is desired, in one embodiment the new programming inforrration for 
each device to be reprogrammed is downloaded to the gaming terminal and the gaming terminal begins downloading 
the information to the attached peripherals preferably only after alt information has been downloaded to the terminal. In 

75 this way. only a single session of downloading to the gaming terminal is needed in order to provide eventual updating 
of two or nrK>re coupled peripherals or other components. In situations in which security is a concern, such as systems 
in which money handling occurs fQ.g.. gaming terminals, lottery terminals, and the like), it may be useful tor the infor- 
mation to be enaypted when it is transferred to the computing device and is decrypted preferably in the gaming termi- 
nal. In one embodiment the invention includes providing at least a first menrory in a ganriing terminal as a 

20 progranvnable memory; transmitting first information from an extemal source to tiie gaming device; transmitting the first 
information for receipt by said peripheral device; storing the first information in the first memory; and using the first infor- 
nf)atk)n during operation cf the peri^&al device. Preferably such a method includes identification of the gaming termi- 
nal hardware or software, preferably using one or more memory devices which have identifying and/or characteristic- 
indicating information stored in non-erasable, non-modifiable menwry, such as OTP/AO memory. 

25 [0034] Downloading can be performed locally (e.g. by connection of a laptop 128 or other computer to the commu- 
nications board 124 of a gaming terminal 1 12a or remotely from a local controller 1 14a or central computer 116. Pref- 
erably the downloading includes verifying the propriety of the software to be downloaded and/or verifying or adjusting 
download procedures (data transfer rate, error detection/con-ection procedures and the like) so tiiat tiie download will 
result in a gaming terminal that is appropriately configured artd operates as desired. Preferat>ly, it is the source compu- 

30 ter 128. 116 which performs such verifying. It is noted, however, that while such source-based checking will assist in 
eliminating or reducing the occurrence of. e.g. Inadvertently inappropriate downloads, it might be possible to configure 
a laptop 128 to purposely download incorrect or inappropriate software. Accordingly, it woukj also t>e possit^le to con- 
figure the destination (the gaming terminal) in such a way tiiat it will actively block or prevent downloading of software 
unless the software to be downloaded is identified by the destination (gaming terminal) as appropriate (based, at least 

35 in part, on inforn^tion stored in OTP/AO memory). In this way. if an attempt was made to download a version of gaming 
software which, e.g.. did not include a properiy encrypted password for authenticating that the proposed download soft- 
ware has been approved by the appropriate gaming regulatory authorities, tiie gaming terminal 1 12a would, preferably, 
block or prevent the downloading of such software. 

[0035] Arx>ther example of a use of information read from OTP/AO memory in a gaming terminal is to verify war- 

40 ranty coverage for servidr^g or repair of a gaming terminal. For example, if a particular gaming terminal was covered by 
a one-year warranty, it would be possible to configure the system such that a service person coukJ determine the date 
of sale or delivery of a gaming ternrvnai (or a component thereof), either directly or indirectly, based on information read 
from OTP/AO memory. As noted above, particularly in tiie case of AO menrxjry. it is useful to configure a system to 
always read the entire memory row, e.g. to avoid a situation in which a new AO memory field is written witii an incorrect 

45 sale date indicator (either inadvertently or intentionally). 

[0036] Another situation In which information stored in OTP/AO memory may be used includes the manufacturing 
process and in particular the management of software downloading as part of a gaining terminal manufacturing proc- 
ess. An example of a use of component identification in connection with such management is described, e.g.. U.S. pat- 
ent application no. (attorney file no. 3735-925) titled "Program Management for Downloadal)le 

so Devices", filed on even date herewith and incorporated herein by reference. Briefly, information stored in OTP/AO mem- 
ory can be used in a number of such management procedures including verifying that the hardware present in a partic- 
ular gaming terminal or component is compatible with a particular download procedure (e.g. a download bit rate or error 
detection/correction procedure) and/or that the software is compatible with or appropriate for the hardware (or other 
software) present in the gaming terminal or connponerrt (e.g. the software is compatible with tiie particular microproc- 

55 essor present in the gaming terminal or component). Furthernrwre. information in OTP/AO memory may be used at tiie 
completion of the gaming terminal assembly (and/or intermediate assembly stages) to verify that the various conrpo- 
nents of tiie gaming terminal are compatible with one another (e.g.. ttie gaming terminal does not have a bill acceptor 
appropriate for a first jurisdiction and a coin handler board appropriate tor a second (different) jurisdiction) and/or tiie 
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components and software in the gaining terminal are configured as desired (e.g. are approved for the gaming jurisdic- 
tion for which the gaming terminal is being txjilt), includes the correct game software (e.g. does not download a poker 
game software when the terminal was intended to be a slot machine) arxl has the correct (typically most recent) version 
of software appropriate for the configuration of the gaming terminal. AdditionaJly, information read from OTP/AO mem- 

5 ory may be used in the management procedures to store appropriate information ri a database. As noted at>ove. in 
some configurations, a database is used to provide information atxiut a gaming terminal, its corrfiguraUon, components 
or history with such information t>eing indexed, in the datat>ase, by information obtained from OTP/AO memory {e.g. a 
memory serial number or similar identifier number). Accordingly, as a gaming temiinal is asserTt)led, it is preferred, in 
at least this configuration, to read information from OTP/AO memory of the gaming terminal and its conponents. and 

10 store such information in a datat^ase. preferably in a fashion to achieve the desired database trxlexing or similar func- 
tion. 

[D037] In ligm of the above description, a number of advantages of the present invention can be seen. The present 
Invention provides a way to iderrtify a gaming terminal or its components in such a fashion as to substantially guard 
against inadvertent or intentional alterations (e.g. so as to increase the likelihood that gaming regulatory authorities will 

15 approve certain manufacture, assenrtily, repair and/or download procedures, particularly ttiose which are at least par- 
tially automated and/or remote) by providing automatically accessible identification or characteristic information as part 
of tiie physical structure of tiie gaming temiinal or component (e.g. as part of a memory mounted on a gaming terminal 
board). Preferably, the information travels witii the gaming terminal or component and tfujs is automatically present and 
correct regardless of any changes (such as replacement of one or more boards of a gaming terninal). Because ttie 

20 information can be electronically programmed or stored (once only), ttie particular information which is provided or 
stored can be tailored to accommodate the conterrplated use of the information (e.g. different manufacturers and/or dif- 
ferent models or model lines of a given manufacturar may involve storing different information and/or storage in differerrt 
formats). Because the stored information is provided elecf onically (rattier ttian, e.g., provided as information printed or 
written on a circuit board) the likelihood of inadvertent or Intentional modification of such information is lessened. 

25 [0038] A number of variations and modifications of the invention can also be used. In general, it is possible to use 
some aspects of ttie invention without using others. For example, it is possible to provide non-erasable and non-modi- 
fiable information in connection with downloading software without providing Information usable for or used with war- 
ranty verification. It is possible to store information in an encrypted or othenwise modified form. In one embodiment, 
some or all of the information which is used (e.g. in connection witii downloading warranty verification and the like) 

30 and/or output from the device is stored in ottier menrwry or memory portions, such as normal EEPROM memory 214, 
e.g. wrtti CJTP/AO memory being used only for permitting access and/or verifying such memory (e.g. by providing ari 
encryption key/decryption key. data integrity check information or the like). Arthough ttie non-erasalDle/modif iable mem- 
ory is disclosed as being a portion of. or coupled to, normal EEPROM memory, it may be provided as a separate com- 
ponent or may be coupled to ottier types of memory. Although examples are provided in which a single row of OTP/AO 

35 memory is provided, more or fewer OTP/AO memory locations may be used. 

[0039] In one embodiment, the gaming terminal is configured such ttrat if an attenrpt is made to dowvnioad certain 
types of improper software, ttie gaming terminal will be placed in an inoperative mode and/or notification of ttie attertpt 
will be output e.g. to a local controller 114 or a certral computer 116. Although, as noted, above, there are advantages 
to providing storage of characteristic-indicating information in electronic fomri. in one en^xxjiment. information relating 

40 to characteristics (e.g. serial number, manufacture date or ttie like) may be stored or presented in optical (e.g. machine 
readable, bar code, or human readable form) e.g. on one or more of the gaming terminal tx)ards. In ttiis case, it may be 
useful to include a step wfiich involves comparing the optical characteristic indicator witti electt-onically-stored charac- 
teristic irxjicators. 

[0040] The present invention, in various embodiments, includes corrponents. mettiods, processes, systems and/or 
45 apparatus sii>starrtially as depicted and described herein, including various embodiments, subcombinations, and sub- 
sets thereof. The present invention, in various embodiments, includes providing devices and processes in the absence 
of items not depicted and/or described herein or in various embodiments hereof, including in the absence of such items 
as may have been used in previous devices or processes. e.g. for achieving ease and reducing cost of implementation. 
[0041] The foregoing discussion of the invention has been presented for purposes of illustration and description. 
50 The foregoing is not intended to limit the invention to tiie form or forms disclosed herein. Alttiough the description of ttie 
invention has included description of one or more embodiments and certain variations and modifications, other varia- 
tions and modifications are within ttie scope of the invention, e.g. as may be within the skill and knowledge of those in 
ttie art. after understanding ttie present disdosura It is intended the appended claims be consto*ued to include alterna- 
tive embodiments to the extern pemnitted. 

55 

Claims 

1, A method for downloading programming to a gaming terminal from a remote site, wherein said prograrr¥ning can 
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appropriately be downloaded only to a ganung terminal with components having at least a first set of characteris* 
tics, the method comprising: 

providing a gaming terminal having at least a first circuit board with a memory, at least a portion of which is 
5 non-erasable memory; 

storing in said non-ereisable memory, at least first i n form a tion indicative of characteristics of said first drcutt 
tx>ard: 

transmitting said first information from said ganning terminal to said remote site; 

downloading said information only if said characteristics of said first circuit tx>ard match said first set of char- 
10 acteristics. 

2. A method, as claimed in daim 1 , wherein said nm-emsatiie memory is one-time programmable memory. 

3w A method as ctaimed in claim 2 wherein said step of tfEuismitting compr^es transmitting all prograimted portions 
IS of said one-time progranvnatsie memory. 

4. A method, as claimed in daim 1, wherein said information indicative of characteristics of said first circuit board 
includes information selected from the grotp consisting of 

20 merrx>ry serieU number 

an Identification numt>er 
date of manufacture 
platform 
target 

2S vendor identification 

board clock speed 
processor type. 

5. A method, as claimed in daim 1 , further comprising: 

30 

using said information irxiicative of characteristics of said first circuit kx>ard to identify a gaming jurisdiction 
location of said gaming terminal; and 

downloading said programming only if said programming has been approved for Seud gaming jurisdiction. 

3S 6. A method, as datmed in claim 1 wherein said step of providing conprises providing an EEPROM which is config- 
ured with a row of one-time programmat)le memory. 

7. A method, as claimed in claim 1 . wherein a plurality of programs is stored at said remote location and further com- 
prising using said information indicative of characteristics of said first drcuit board to select a program for down- 

40 loading to said gaming terminal. 

8. A method, as daimed in claim 1 . wherein said step of transnritting is performed in response to a query sent from 
said remote location to said gaming terminal. 

45 9. Apparatus usable for downloading programming to a gaming terminal from a renxjte site, wherein said program- 
ming can appropriately be downloaded only to a gaming termir^ with components having at least a first set of 
characteristics, the apparatus comprising: 

at least a first circuit board in said gaming terminal having with a memory, at least a portion of which is non- 
50 erasable menrK>ry. at least first information indicative of characteri^ics of said fyrst drcuit board stored in said 
non-erasable memory 

means for transmitting said first irrformation from said gaming terminal to said remote site; 

means for downloading said information only if said characteristics of said first drcuit board match said first set 

of characteristics. 

55 

10. Apparatus, as claimed in claim 9 wherein said memory comprises read-only memory. 

11. Apparatus, as claimed in claim 9 wherein said memory comprises EPROM memory. 
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12. Apparatus, as claimed in claim 9, wherein said non-erasable memcxy is one-time programmal)le memory. 

13* Apparatus as claimed in claim 12 wherein said meas for transmitting transmits ail programmed portions of said 
one-time progranmable memory. 

5 

14, Apparatus, as claimed in daim 9. wherein said information incficative of characteristics of said first arcurt board 
includes information selected from the group consisting of 

memory serial number 
TO an Identification number 

date of manufacture 
platform 
target 

verKtor identification 
15 tx>£ud dock speed 

processor type. 

15. Apparatus, as claimed in claim 9, further comprising: 

20 means for identifying a gaming jurisdiction location of said gaming terminal using said information indicative of 

characteristics of said first drcuit board; arxi 

means for downloading said programming only if said programming has been approved for said gaming juris- 
diction. 

25 16. Apparatus, as claimed in claim 9; wherein a plurality of programs is stored at said remote location and ftjrther com- 
prising means for selecting a program for downloading to said gaming terminal, using said information indicative of 
characteristics of said first circuit board. 

17. Appeuatus. as claimed in claim 9, wherein said first drcuit board is a game contrdler board; 

30 

18. Apparatus, as daimed in claim 9 wherein said first drcuit t)oard is a peripheral controller board. 
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